java中数组和链表结构

java中数组和链表结构

  1. 数组:这里的数组都是java代码实现的数组,java数组有一个特点就是创建的时候必须给定一个长度,并且长度无法改变,如果数组的长度满了,那在一般集合中都会进行扩容,所以扩容的方式是再创建一个更大的数组,将以前数组的数据进行复制到新的数组中,数组在内存中存在的方式一定是连续的

  2. 单向链表:每一节点储存2个域

    • 要存入的对象

    • 下一个节点的内存地址(指针)

      在内存中一般不是可连续的,查询的时间复杂程度为O(n),因为查询需要按照顺序遍历,而删除插入只需要改动写一个节点的内存地址,最后一个元素的指针是null

  3. 双向链表:每个节点储存3个域

    • 上一个节点的内存地址

    • 要存入的数据

    • 下一个节点的内存地址

      和单向链表就多一个上一个节点的指针,好处是删除,插入的时候只需要遍历一次,而单向链表是没有是没有上一个指针的,就需要再遍历一次

  4. 循环链表:和单向链表一样就是最后一个元素的指针域是指向第一个元素

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值